package com.kantboot.system.user.dao.repository.entity;

import com.kantboot.system.user.domain.entity.SysUserRole;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;

import java.util.List;

/**
 * 用户角色关联表
 */
public interface SysUserRoleRepository extends JpaRepository<SysUserRole,Long> {

    /**
     * 根据用户id和角色code查询
     * @param userId 用户id
     * @param roleCode 角色code
     * @return 用户角色关联表
     */
    SysUserRole findByUserIdAndRoleCode(Long userId, String roleCode);

    /**
     * 根据用户id获取角色编码列表
     */
    @Query("""
    SELECT ur.roleCode
    FROM SysUserRole ur
    WHERE ur.userId = :userId
    """)
    List<String> getRoleCodeListByUserId(Long userId);

    @Query("""
        SELECT ur FROM SysUserRole ur
        WHERE ur.userId = :userId
        AND ur.roleCode != 'admin'
        """)
    List<SysUserRole> findNotAdminByUserId(Long userId);

}
